package com.huike.web.controller.review;


import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import com.huike.review.vo.MybatisReviewVO;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    /**=========================================================新增数据============================================*/

    @GetMapping("/saveDate/{name}/{age}/{sex}")
    public AjaxResult save(MybatisReviewVO reviewVO){
        String save = reviewService.save(reviewVO);
        return AjaxResult.success(save);
    }
    @PostMapping("/saveDate/{name}/{age}/{sex}")
    public AjaxResult addInfo(@PathVariable("name") String name ,@PathVariable("age") String age, @PathVariable("sex") String sex){

        String saveInfo = reviewService.saveInfo(name, age, sex);

        return AjaxResult.success(saveInfo);
    }
    /**=========================================================删除数据=============================================*/

    @DeleteMapping("/remove/{id}")
    public AjaxResult deleteById(@PathVariable("id") Long id){

        String deleteById = reviewService.deleteById(id);
        return AjaxResult.success(deleteById);
    }

    /**=========================================================修改数据=============================================*/

    public AjaxResult update(@RequestBody MybatisReviewVO reviewVO){

        String update = reviewService.update(reviewVO);
        return AjaxResult.success(update);
    }

    /**=========================================================查询数据=============================================*/
   @GetMapping("/getDateByPage")
    public TableDataInfo selectPage(){
       startPage();
        List<Review> reviews = reviewService.selectPage();
        return getDataTable(reviews);
    }

    @GetMapping("/getById")
    public AjaxResult selectById(@PathVariable("id") Long id){
        Review review = reviewService.selectById(id);
        return AjaxResult.success(review);
    }
}